<!--
  ~ Licensed to the Apache Software Foundation (ASF) under one or more
  ~ contributor license agreements.  See the NOTICE file distributed with
  ~ this work for additional information regarding copyright ownership.
  ~ The ASF licenses this file to You under the Apache License, Version 2.0
  ~ (the "License"); you may not use this file except in compliance with
  ~ the License.  You may obtain a copy of the License at
  ~
  ~     http://www.apache.org/licenses/LICENSE-2.0
  ~
  ~ Unless required by applicable law or agreed to in writing, software
  ~ distributed under the License is distributed on an "AS IS" BASIS,
  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  ~ See the License for the specific language governing permissions and
  ~ limitations under the License.
  -->

<div class="relative h-full">
    <div class="reporting-task-table listing-table absolute inset-0 overflow-y-auto">
        <table
            mat-table
            [dataSource]="dataSource"
            matSort
            matSortDisableClear
            (matSortChange)="sortData($event)"
            [matSortActive]="initialSortColumn"
            [matSortDirection]="initialSortDirection">
            <!-- More Details Column -->
            <ng-container matColumnDef="moreDetails">
                <th mat-header-cell *matHeaderCellDef></th>
                <td mat-cell *matCellDef="let item">
                    @if (canRead(item)) {
                        <div class="flex items-center gap-x-2">
                            @if (hasComments(item)) {
                                <div
                                    class="pointer fa fa-comment primary-color"
                                    [delayClose]="false"
                                    nifiTooltip
                                    [tooltipComponentType]="TextTip"
                                    [tooltipInputData]="item.component.comments"></div>
                            }
                            @if (hasErrors(item)) {
                                <div
                                    class="pointer fa fa-warning has-errors caution-color"
                                    [delayClose]="false"
                                    nifiTooltip
                                    [tooltipComponentType]="ValidationErrorsTip"
                                    [tooltipInputData]="getValidationErrorsTipData(item)"></div>
                            }
                            @if (hasBulletins(item)) {
                                <div
                                    class="pointer fa fa-sticky-note"
                                    [ngClass]="getBulletinSeverityClass(item)"
                                    [delayClose]="true"
                                    nifiTooltip
                                    [tooltipComponentType]="BulletinsTip"
                                    [tooltipInputData]="getBulletinsTipData(item)"></div>
                            }
                        </div>
                    }
                </td>
            </ng-container>

            <!-- Name Column -->
            <ng-container matColumnDef="name">
                <th mat-header-cell *matHeaderCellDef mat-sort-header>Name</th>
                <td mat-cell *matCellDef="let item">
                    <div
                        [ngClass]="{ unset: !canRead(item), 'neutral-color': !canRead(item) }"
                        class="overflow-hidden overflow-ellipsis whitespace-nowrap">
                        {{ formatName(item) }}
                    </div>
                </td>
            </ng-container>

            <!-- Type Column -->
            <ng-container matColumnDef="type">
                <th mat-header-cell *matHeaderCellDef mat-sort-header>Type</th>
                <td mat-cell *matCellDef="let item">
                    {{ formatType(item) }}
                </td>
            </ng-container>

            <!-- Bundle Column -->
            <ng-container matColumnDef="bundle">
                <th mat-header-cell *matHeaderCellDef mat-sort-header>Bundle</th>
                <td mat-cell *matCellDef="let item">
                    {{ formatBundle(item) }}
                </td>
            </ng-container>

            <!-- State Column -->
            <ng-container matColumnDef="state">
                <th mat-header-cell *matHeaderCellDef mat-sort-header>State</th>
                <td mat-cell *matCellDef="let item">
                    <div class="flex items-center gap-x-2">
                        <div [ngClass]="getStateIcon(item)"></div>
                        <div>{{ formatState(item) }}</div>
                        @if (hasActiveThreads(item)) {
                            <div>({{ item.status.activeThreadCount }})</div>
                        }
                    </div>
                </td>
            </ng-container>

            <!-- Actions Column -->
            <ng-container matColumnDef="actions">
                <th mat-header-cell *matHeaderCellDef></th>
                <td mat-cell *matCellDef="let item">
                    <div class="flex items-center justify-end gap-x-2">
                        <button
                            mat-icon-button
                            type="button"
                            [matMenuTriggerFor]="actionMenu"
                            class="h-16 w-16 flex items-center justify-center icon global-menu">
                            <i class="fa fa-ellipsis-v"></i>
                        </button>
                        <mat-menu #actionMenu="matMenu" xPosition="before">
                            <button mat-menu-item (click)="configureClicked(item)">
                                <i class="fa fa-cog primary-color mr-2"></i>
                                {{ canEdit(item) ? 'Edit' : 'View Configuration' }}
                            </button>
                            @if (hasAdvancedUi(item)) {
                                <button mat-menu-item (click)="advancedClicked(item)">
                                    <i class="fa fa-cogs primary-color mr-2"></i>
                                    Advanced
                                </button>
                            }
                            @if (canStop(item)) {
                                <button mat-menu-item (click)="stopClicked(item)">
                                    <i class="fa fa-stop primary-color mr-2"></i>
                                    Stop
                                </button>
                            }
                            @if (canStart(item)) {
                                <button mat-menu-item (click)="startClicked(item)">
                                    <i class="fa fa-play primary-color mr-2"></i>
                                    Start
                                </button>
                            }
                            @if (canChangeVersion(item)) {
                                <button mat-menu-item (click)="changeVersionClicked(item)">
                                    <i class="fa fa-exchange primary-color mr-2"></i>
                                    Change Version
                                </button>
                            }
                            @if (canDelete(item)) {
                                <button mat-menu-item (click)="deleteClicked(item)">
                                    <i class="fa fa-trash primary-color mr-2"></i>
                                    Delete
                                </button>
                            }
                            @if (canViewState(item)) {
                                <button mat-menu-item (click)="viewStateClicked(item)">
                                    <i class="fa fa-tasks primary-color mr-2"></i>
                                    View State
                                </button>
                            }
                            @if (canClearBulletins(item)) {
                                <button mat-menu-item (click)="clearBulletinsClicked(item)">
                                    <i class="fa fa-eraser primary-color mr-2"></i>
                                    Clear Bulletins
                                </button>
                            }
                            @if (canRead(item)) {
                                <button mat-menu-item (click)="viewDocumentationClicked(item)">
                                    <i class="fa fa-book primary-color mr-2"></i>
                                    View Documentation
                                </button>
                            }
                            @if (canManageAccessPolicies()) {
                                <button mat-menu-item (click)="managedAccessPoliciesClicked(item)">
                                    <i class="fa fa-key primary-color mr-2"></i>
                                    Manage Access Policies
                                </button>
                            }
                        </mat-menu>
                    </div>
                </td>
            </ng-container>

            <tr mat-header-row *matHeaderRowDef="displayedColumns; sticky: true"></tr>
            <tr
                mat-row
                *matRowDef="let row; let even = even; columns: displayedColumns"
                (click)="select(row)"
                [class.selected]="isSelected(row)"
                [class.even]="even"></tr>
        </table>
    </div>
</div>
